package 第一周;

/**
 * @author xhw
 * @date 2024/2/18
 */

public class 找出字符串中第一个匹配项的下标 {
    //题目要求给你两个字符串 haystack 和 needle
    //请你在 haystack 字符串中找出 needle 字符串的第一个匹配项的下标（下标从 0 开始）。
    //如果 needle 不是 haystack 的一部分，则返回  -1 。

    //示例 1：
    //输入：haystack = "sadbutsad", needle = "sad"
    //输出：0
    //解释："sad" 在下标 0 和 6 处匹配。
    //第一个匹配项的下标是 0 ，所以返回 0 。

    //示例 2：
    //输入：haystack = "leetcode", needle = "leeto"
    //输出：-1
    //解释："leeto" 没有在 "leetcode" 中出现，所以返回 -1 。

    //提示：

    //1 <= haystack.length, needle.length <= 104
    //haystack 和 needle 仅由小写英文字符组成
    public static void main(String[] args) {
        String haystack = "a";
        String needle = "a";

        System.out.println(findIndex(haystack, needle));

    }

    //假如不加-那么返回很有可能超出下标
    private static int findIndex(String haystack, String needle) {
        for (int i = 0; i <= haystack.length() - needle.length(); i++) {
            if (haystack.substring(i, i + needle.length()).equals(needle)) {
                return i;
            }
        }
        return -1;
    }
}
